SYSTEM AND METHOD FOR IDENTIFYING APPLICATIONS 
LOADED IN A SMART CARD 


Field of the Invention 

5 The present invention is related to smart cards, and in particular, a smart card having a 

display for displaying currently loaded applications. 

Background of the Invention 

As is well known, a smart card is a portable device, usually similar in size to a credit 

1 0 card, that contains a processing logic and memory for storing information. The smart card 
generally contains all the intelligence necessary to complete a transaction locally at the 
transaction location. Depending on the complexity of the smart cards, they offer virtually 
unlimited application possibilities. The applications may include such transactions as an 
electronic purse, prepaid telephone, highway toll collection, frequent flier mileage tracking, 

1 5 personal finance, and personal authentication. The smart card may also be used to store personal 
information, health care data or the like. 

As the number of available applications grows, popularity of a smart card containing 
multiple applications is expected to increase substantially. Multi-application smart cards are 
known. For example, U.S. Patent No. 5,530,232 issued to Taylor on June 25, 1996 describes a 

20 multi-application smart card that uses multiple memory banks to store data related to the multiple 
applications. 

However, the applicant of the present invention recognized that one of the problems in a 
wide-spread adoption of a multi-application smart card by the industry is that there is no easy 
way for a user to find out what applications reside in the card. The problem is compounded if 


the user holds two or more multi-application cards. One solution is to permanently print the 
symbols or logos of the applications on the card at the time of issuance. As can be appreciated, 
however, this solution is inadequate. Even though different applications may be loaded and 
removed from the card from time to time, the permanent printing of the logos cannot be changed 

5 to accurately reflect the currently loaded applications. Another solution is to use an external 
reader device that slips over the card to view the card's content. Such a device, however, is too 
bulky to carry around with the card. 

Therefore, it can be appreciated that there is a need to provide a convenient system and 
method for identifying which applications are currently available in a multi-application smart 

10 card. 


Summary of the Invention 

According to the principles of the present invention, there is provided a smart card that is 
capable of identifying the currently loaded application programs. The smart card includes a 
1 5 memory for storing application programs and their associated symbols or logos, and a processor 
capable of executing the stored programs. According to the invention, the smart card includes a 
display that can display the stored symbols of the loaded application programs for easy 
identification by the user. 

As can be appreciated, the present invention provides the advantage of allowing a user to 
20 see which application programs are currently available at all times as different application 
programs are loaded and deleted from time to time. 

To provide even more convenience for the user, in one embodiment, the processor 
displays the programs according to how frequently they are used by the user. 
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Brief Description of the Drawings 

FIG. 1 is a block diagram of a smart card according to the present invention. 
FIG. 2 illustrates an exterior side of the smart card. 

FIG. 3 is a flow diagram of a method for loading and removing application programs, and 
5 displaying associated symbols on a display of the smart card. 

FIG. 4 is a flow diagram of a method for viewing user information associated with a 
loaded application program. 


Detailed Description of the Invention 

FIG. 1 is a block diagram of a smart card 10 that is capable of displaying symbols or 
logos of loaded application programs according to the present invention. The smart card 10 
includes an interface 14, input device 16, processor 18, display 12 integrated into the smart card 
housing and memory 20 which are all connected to a common bus 22. FIG. 2 illustrates an 
exterior side of the card 10. 
15 The display 12 can be any display that are commonly used for portable devices. For 

example, the display 12 can be a liquid crystal display (LCD), electronic ink display (EID), light 
emitting display (LED), thin film transistor (TFT) display, field emission display (FED) or the 
like. In one embodiment, the display 12 is an LCD film of a bi-stable or multi-stable material 
such that it will maintain an image when power has been removed. In this way, the smart card 
20 10 requires no internal power source to permanently display currently available application 
programs for viewing by the user. 

The interface 14 transfers various data and control signals between the smart card 10 and 
an external system (not shown). The interface 14 may be contact-less such as an RF transceiver 
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to transmit and receive data and control signals. Alternatively, the interface 14 may be contact 
based which requires the smart card 10 to come in contact with the external system. The external 
system may be a card reader, a point of sale system, automated teller machine, or the like. 

The input device 16 may be a standard membrane key pad with directional keys 34 and a 
5 selection key 36. Alternatively, the device 16 can be a part of the display 12 such as a touch 
sensitive display that are commonly used in personal digital assistants (PDAs'). Still another 
alternative is a thumb wheel device or a voice recognition device found in certain cellular 
telephones. The input device 16 is used for navigating between application programs and 
selecting a particular program as will be explained in detail later herein. 

^10 In another embodiment, no input device may be present as the external system will 

■2 automatically select a proper application to run. 

JiJ The memory 20 may contain many different types such as read only memory (ROM), 

U random access memory (RAM), and non-volatile memory (NVM). The memory 20 stores 
Q programs that are executed by the processor 1 8. As shown in FIG. 1, the memory 20 stores a 
[yi5 loader program 24, execution control program 26, and one or more application programs 30 and 
5 3 their associated symbols 32. The loader program 24 controls loading and removing of 

application programs 30 and associated application symbols from the smart card memory 20 as 
shown in FIG. 3. As part of the loading or removing process, the loader 24 may verify or 
authenticate that the external system desiring to load or remove an application program has the 
20 appropriate authority to do so. 

Once the application programs 30 and symbols 32 are loaded, the execution control 
program 26 controls the user's navigation among the displayed symbols, display of user 
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information, and which application program 30 is launched or executed at a certain point in time 

as illustrated in FIG. 4. 

Referring to FIG. 2, the input device 16 includes a set of directional keys 34 which are 
used as navigation inputs and a selection key 36 which will be explained in detail later herein. 
The display 12 as shown has 3 rows or lines, and are divided into 9 uniform logical blocks 13. 
Each block 13 is capable of displaying a symbol 32 associated with a loaded application program 
30. Each symbol 32 stored in the memory 20 is preferably a graphic image of a logo associated 
with the application program although the symbol can be a name of the application or even a 
single letter. As shown, the display 12 is displaying four symbols "A", "B", "C" and "D" which 
represent the logos of entities that provide the four application programs 30 stored in the card 10. 
It is to be noted that while each block is shown in FIG. 2 as uniform in size, they can be of 
different sizes to allow one symbol to be more prominently displayed than the others. 

FIG. 3 is a flow diagram of a method for loading and removing application programs, and 
displaying associated symbols on a display 12 of the smart card 10. The software code for the 
flow diagram of FIG. 3 is contained in the loader program 24. In step 40, the card 10 receives a 
request to either add or delete an application program 30. The request is generally transmitted by 
an external system in communication with the processor 18 through the interface 14 and is 
received by the loader program 24. In step 42, it is determined whether the request was an add 
request. If yes, control passes to step 44 where the application program 30 is received by the 
card 10 and stored in the memory 20. hi step 46, the card receives a symbol 32 associated with 
the application program that was just received in step 44. Preferably, the symbol 32 is in a 
graphic file format suitable for display in the display 12. The symbol 32 may be a logo of an 
entity that provides the application program 30. For example, if the application provides a 


prepaid telephone transaction service, the symbol 32 may be a logo of the telephone service 
provider. 

If it was determined that the request was not an add request, control passes to step 48 and 
it is assumed that the request was a delete request. In step 47, the loader program 24 receives a 
5 program identifier that identifies which application program to delete. In step 48, a selected 
application program identified in step 47 is deleted from the memory 20. In step 50, the 
associated symbol is also deleted from the memory 20. 

In step 52, the loader program 24 determines whether there are more requests from the 
external system. If yes, control passes to step 40 and the above steps are repeated. If no more 
2l0 requests are pending, the program 24 continues with step 54. In step 54, the display locations of 
S the currently stored symbols 32 are determined. While step 54 is performed by the smart card 
rj processor 1 8, it can be alternatively performed by the external system (not shown) prior to step 
40. 

□ There are many methods by which the display locations can be determined. Some 

3f 15 possibilities include random placements, alphabetically arranged placements and sequential 
=: placements in the order the programs are received by the smart card 10. Alternatively, the 

display locations can be predetermined based on premiums paid to the card issuer by providers 
of the application programs 30. Optionally, the size of the symbols 32 can be varied, for 
example, according to the program usage with the most frequently used one having a larger size. 
20 Preferably, once the card is in use, the display locations can be determined based on usage of the 
application programs 30 with the most frequently used programs' symbols appearing first on the 
display 12 or more prominently than other symbols. Alternatively or in addition to such a 
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method based on frequent usage, the symbol for the last used application program can be 
displayed first or more prominently than other symbols in the display 12. 

Once the display locations have been determined, in step 56, the symbols 32 are retrieved 
from the memory 20 and displayed in the display 12 according to the determined locations. 
5 According to the principles of the present invention, the display 12 always reflects all currently 
loaded applications. As can be appreciated, the user now has the benefit of being able to see 
what applications are currently available at all times, even if the user holds multiple multi- 
application cards. 

FIG. 4 is a flow diagram of a method for viewing user information associated with any 
loaded application program which illustrates further advantages of the present invention. The 
S software code for the flow diagram of FIG. 4 is contained in the execution control program 26. 
m In step 60, the card 10 receives any one of the key inputs 34, 36 which indicates that the user 
U wishes to turn on or "activate" the card 10. In response, the execution control program 26 in step 
O 62 highlights (for example using a reverse video, underlining, or the like) the first displayed 
Oh 5 symbol or the last used symbol to acknowledge that the card 1 0 has been "turned on". In step 
R 64, the program 26 receives another key input from the user. In step 66, it is determined whether 
the key input is a directional key 34. If yes, control passes to step 62 where an appropriate 
symbol is highlighted. For example, if symbol "A" had been highlighted when a right 
directional key 34 is pressed, then symbol "B" would be highlighted in step 62. 
20 If the decision is no in step 66, the program 26 assumes that the selection key 36 has been 

pressed and continues at step 68. At step 68, user information associated with the selected 
application program is displayed. The types of user information varies with the application 
programs 30. For example, if the program 30 is a prepaid telephone time application, one user 


information may be the number of minutes remaining in the application. As another example, if 
the program is a credit card account application, a user information may include the remaining 
amount of credit to be charged. As still another example, if the program is a prepaid video rental 
application, the user information may include the number of remaining rentals available for 
5 consumption and the number of rentals that have been consumed by the user. 

In an alternative embodiment, the user information is automatically displayed as the user 
is navigating among the displayed symbols without the use of the selection key 36. 

In another alternative embodiment, the input device 16 consists of a single key which, 
when pressed, will scroll through the displayed application symbols one at a time with each key 
jiO input and automatically display the user information of each application as it scrolls. 
S In step 70, the card 10 receives another key input. In step 72, it is determined whether 

n the received key input is a selection key. If no, control passes to step 62 where the control 
^ program 26 highlights the last selected symbol and awaits further input at step 64 from the user. 
3 If the received key input is the selection key, it is assumed that the user has selected and 
ill 5 effectively locked in the currently highlighted application program for use at that time. In this 
3 way, it is a more secure method of using the smart card although it may be more convenient to 
let the external system select a particular application program in the card. In step 74, the 
highlighted program is selected for execution by the processor 18 and any request from the 
external system to run any other application program is rejected by the smart card 10. 
20 From the foregoing, it will be appreciated that, although specific embodiments of the 

invention have been described herein for purposes of illustration, various modifications maybe 
made without deviating from the spirit and scope of the invention. For example, while the smart 
card has been illustrated with only one processor, persons of ordinary skill in the art can 
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appreciate that the card can have multiple processors that are segregated from each other to 
provide higher security. Accordingly, the present invention is not limited except as by the 
appended claims. 


